/**
*
Java Diagram Package; An extremely flexible and fast multipurpose diagram
component for Swing.
Copyright (C) 2001 Eric Crahen <crahen@cse.buffalo.edu>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package diagram;
import java.awt.Shape;
import java.awt.geom.Point2D;
import java.awt.geom.Rectangle2D;
/**
* @interface Figure
*
* @date 08-20-2001
* @author Eric Crahen
* @version 1.0
*
*/
public interface Figure extends Shape {
/**
* Get the anchor for the Figure. This is usually the center
* of the Figure but does not always have to be.
*
* @param Point2D use to avoid allocating a new object
*
* @return Point2D
*/
public Point2D getAnchor(Point2D pt);
/**
* Get the rectangular bounds of this figure.
*
* @param Rectangle2D, use to avoid allocating a new object
* @return Rectangle2D
*/
public Rectangle2D getBounds2D(Rectangle2D rc);
/**
* Get the center of this figure.
*
* @param Point2D use to avoid allocating a new object
* @return Point2D
*/
public Point2D getCenter(Point2D pt);
/**
* Point on the boundary of this figure closest to some
* point outside this figures.
*
* @param Point2D point outside this Figure to connect to
* @param Point2D use to avoid allocating a new object
* @return Point2D
*/
public Point2D getConnection(Point2D ptFrom, Point2D pt);
/**
* Change the bounds for this Figure
*
* @param double
* @param double
* @param double
* @param double
*/
public void setBounds(double x, double y, double w, double h);
/**
* Translate this figure.
*
* @param double
* @param double
*/
public void translate(double x, double y);
/**
* Clone support
*/
public Object clone();
}